home *** CD-ROM | disk | FTP | other *** search
/ Openstep 4.2 (Developer) / Openstep Developer 4.2.iso / NextDeveloper / Source / GNU / debug / gdb / libiberty / spaces.c < prev    next >
Encoding:
C/C++ Source or Header  |  1996-08-09  |  1.6 KB  |  71 lines

  1. /* Allocate memory region filled with spaces.
  2.    Copyright (C) 1991 Free Software Foundation, Inc.
  3.  
  4. This file is part of the libiberty library.
  5. Libiberty is free software; you can redistribute it and/or
  6. modify it under the terms of the GNU Library General Public
  7. License as published by the Free Software Foundation; either
  8. version 2 of the License, or (at your option) any later version.
  9.  
  10. Libiberty is distributed in the hope that it will be useful,
  11. but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
  13. Library General Public License for more details.
  14.  
  15. You should have received a copy of the GNU Library General Public
  16. License along with libiberty; see the file COPYING.LIB.  If
  17. not, write to the Free Software Foundation, Inc., 675 Mass Ave,
  18. Cambridge, MA 02139, USA.  */
  19.  
  20. /*
  21.  
  22. NAME
  23.  
  24.     spaces -- return a pointer to a buffer full of spaces
  25.  
  26. SYNOPSIS
  27.  
  28.     char *spaces (int count)
  29.  
  30. DESCRIPTION
  31.  
  32.     Returns a pointer to a memory region filled with the specified
  33.     number of spaces and null terminated.  The returned pointer is
  34.     valid until at least the next call.
  35.     
  36. BUGS
  37.  
  38. */
  39.  
  40. #include "ansidecl.h"
  41. #include "libiberty.h"
  42.  
  43. const char *
  44. spaces (count)
  45.   int count;
  46. {
  47.   register char *t;
  48.   static char *buf;
  49.   static int maxsize;
  50.   extern void free ();
  51.  
  52.   if (count > maxsize)
  53.     {
  54.       if (buf)
  55.     {
  56.       free (buf);
  57.     }
  58.       buf = malloc (count + 1);
  59.       if (buf == (char *) 0)
  60.     return 0;
  61.       for (t = buf + count ; t != buf ; )
  62.     {
  63.       *--t = ' ';
  64.     }
  65.       maxsize = count;
  66.       buf[count] = '\0';
  67.     }
  68.   return (const char *) (buf + maxsize - count);
  69. }
  70.  
  71.